<?xml version = '1.0' encoding = 'UTF-8'?>
<HBRRepo><variables><variable name="OQP_Territory" type="member" usage="const" id="1" product="Planning"><property name="application">SalesPln</property><property name="dimensionInputMode">type</property><property name="dimensionType">Territory</property><property name="prompt_text">LABEL_QTP_SLS_PLAN_PRMPT_TERRITORY</property><property name="scope">ruleset</property><property name="seeded">true</property><value/></variable><variable name="OQP_Account" type="member" usage="const" id="2" product="Planning"><property name="application">SalesPln</property><property name="plantype">OEP_QTP</property><property name="dimension">Accounts</property><property name="prompt_text">Enter Account</property><property name="scope">ruleset</property><property name="seeded">true</property><value/><limits type="expression"><property name="value">@Relative("OEP_All Accounts",0)</property></limits></variable><variable name="OQP_QuotaAmt" type="integer" usage="const" id="3" product="Planning"><property name="application">SalesPln</property><property name="plantype">OEP_QTP</property><property name="prompt_text">Enter Quota Amount</property><property name="scope">ruleset</property><property name="seeded">true</property><value/></variable></variables><rulesets/><rules><rule id="1" name="OQP_BottomUp Add Account" product="Planning"><property name="application">SalesPln</property><property name="plantype">OEP_QTP</property><property name="seeded">true</property><variable_references><variable_reference name="OQP_Territory" id="1"><property name="application">SalesPln</property><property name="hidden">true</property><property name="rule_name">OQP_BottomUp Add Account</property><property name="seq">1</property><property name="type">3</property><property name="useAsOverrideValue">false</property><property name="validation_value">"No Entity"</property></variable_reference><variable_reference name="OQP_Account" id="2"><property name="application">SalesPln</property><property name="hidden">false</property><property name="plantype">OEP_QTP</property><property name="rule_name">OQP_BottomUp Add Account</property><property name="seq">2</property><property name="type">3</property><property name="useAsOverrideValue">false</property><property name="validation_value">"OEP_Any Account"</property></variable_reference><variable_reference name="OQP_QuotaAmt" id="3"><property name="application">SalesPln</property><property name="hidden">false</property><property name="plantype">OEP_QTP</property><property name="rule_name">OQP_BottomUp Add Account</property><property name="seq">3</property><property name="type">18</property><property name="useAsOverrideValue">false</property><property name="validation_value">100</property></variable_reference></variable_references><script type="groovy">		/*RTPS:{OQP_Territory}  {OQP_Account} {OQP_QuotaAmt}*/
        /*Purpose: This rule adds an account with Quota Amount for given Territory*/
		def grid=operation.grid;
		List&lt;String> PovMembers=[];
		List&lt;String> ColumnDimensions=[];
		List&lt;String> AggDimensions=[];
        String strAccount="";
		String strCrossDim  = "";
		String strFirstCrossDim="";
		String driverDimMember;
		boolean isUnitsModel =false;
        boolean  isExistingMbr=false;
		int firstColumn=0;
		/*try
		{*/
        /*Evaluate if application is Units or Revenue */
			Application app=operation.getApplication();
             Cube qtp=operation.getCube(); 
              Dimension dim=app.getDimension(DimensionType.ACCOUNT,qtp);
              if (dim.hasMember("OQP_Units",qtp)==true)
              {
                isUnitsModel=true;
                driverDimMember="OQP_Last Year Units";
              }
              else
              {
                isUnitsModel=false;
                driverDimMember="OQP_Last Year Revenue";                    
              }
         strAccount= rtps.OQP_Account.member;    
		StringBuilder cscript = new StringBuilder();
        /*Fetch List of POV members*/
		List&lt;String> fixMemberNames = operation.grid.pov*.essbaseMbrName;
		for(String mbrName:fixMemberNames)
		{
				PovMembers.add('''"'''+mbrName+'''"''');
		}
		/*Fetch list of column members*/
		List&lt;List&lt;DataGrid.HeaderCell>> cols = grid.getColumns();
		for (List&lt;DataGrid.HeaderCell> cells : cols) 
		{
		 firstColumn=0;
			for (DataGrid.HeaderCell cell : cells)  
			  {       
			   String dimName = cell.getDimName();
			   String memName = cell.getMbrName();
			   DimensionType DimType= cell.getDimensionType()
			   if (!ColumnDimensions.contains(dimName))
				  {
					if (!DimType.equals(DimensionType.ACCOUNT) &amp;&amp; !DimType.equals(DimensionType.PERIOD) )
					{
						ColumnDimensions.add(dimName);               
						strCrossDim= strCrossDim + "\"No "+ dimName+"\"->";
						strFirstCrossDim=strFirstCrossDim+'''@MEMBERAT(@RELATIVE("OEP_All '''+dimName+'''",0),1)->''';
						AggDimensions.add('''"'''+dimName+'''"''');
					}
			   
				 }
			   firstColumn++;
			  if (firstColumn==1) 
			  break;
			 }     
		 }
         
         	List&lt;DataGrid.Row> rows = grid.getRows()
			for (DataGrid.Row row : rows) 
			{
				List&lt;DataGrid.HeaderCell> subRows = row.getHeaders();
				for(DataGrid.HeaderCell cell : subRows) 
				  {
					String memName = cell.getMbrName();                      
				  if (memName.equals(strAccount))				   {
						isExistingMbr=true                           
                        break;
				   }     	 
				 }
               if (isExistingMbr==true ) 
               {
               	break;
               }
                 
			}
            
            if (isExistingMbr==true )
            {
            	throwVetoException("This Account is already assigned to the Territory or Resource.Please select new account");            
            }
         /*Start of Main script - Assign Quota amount to Account*/
		cscript.append('''SET AGGMISSG ON;\n''');
		cscript.append('''SET UPDATECALC OFF;\n'''); 
		cscript.append('''FIX(@Relative("Yeartotal",0),'''+PovMembers.join(''',''')+''')\n''')
		cscript.append('''	FIX("'''+rtps.OQP_Territory.member+'''")\n''');
		cscript.append('''		"OQP_Quota"(\n''');
		cscript.append('''			'''+strCrossDim+'''"'''+rtps.OQP_Account.member+'''"->"OQP_Quota"='''+ rtps.OQP_QuotaAmt.getDoubleValue()/12 +''';\n''');
		cscript.append('''			'''+strFirstCrossDim+'''"'''+rtps.OQP_Account.member+'''"->"OQP_Quota"='''+ rtps.OQP_QuotaAmt.getDoubleValue()/12 +''';\n''');
		cscript.append('''		)\n''');
		cscript.append('''	ENDFIX\n''');
		cscript.append('''	FIX("OQP_Quota","'''+rtps.OQP_Territory.member+'''")\n''');
		cscript.append('''		FIX("'''+rtps.OQP_Account.member+'''")\n''')
        cscript.append('''			AGG(''')
        cscript.append(AggDimensions.join(''',''')+''');\n''')
		cscript.append('''		ENDFIX\n''');
		cscript.append('''		@IANCESTORS("'''+rtps.OQP_Account.member+'''");\n''')
		cscript.append('''	ENDFIX\n''');
		cscript.append('''ENDFIX\n''');
		println (cscript.toString())
		return cscript.toString()
	/*	}catch(all) {
			throw new HspRuntimeException('Error occured while Running  Business Rule.');
		}*/		
			
		</script></rule></rules><components/><deployobjects><deployobject product="2" application="salespln" plantype="oep_qtp" obj_id="1" obj_type="1" name="OQP_BOTTOMUP ADD ACCOUNT"/></deployobjects></HBRRepo>